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Distributed by 

The ATARI Program Exchange 
P. O. Box 427 

155 Moffett Park Drive. B-l 
Sunnyvale. CA 94086 

To request an AFX Software Catalog, write to the address above, or ran toll-free? 
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This AFX diskette is unnotched to protect the software against 
accidental erasure* However* this protection also prevents a program 
from storing information on the diskette* The program you've 
purchased involves storing information* Therefore* before you can use' 
the program* you must duplicate the contents of the diskette onto a 
notched diskette that doesn't have a write-protect tab covering the 
notch* 

To duplicate the diskette* call the Disk Operating System (DOS) menu 
and select option J * Duplicate Disk* You can use this option with a 
single disk drive by manually swapping source (the APX diskette) and 
destination (a notched diskette) until the duplication process is 
complete* You can also use this option with multiple disk drive . 
systems by inserting source and destination diskettes in two separate 
drives and letting the duplication process proceed automatically* 

(Note* This option copies sector by sector* Therefore* when the 
duplication is complete* any files previously stored on the 
destination diskette. will have been destroyed*) 
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INTRODUCTION 


OVERVIEW 

INSTEDIT is a character set editor that simultaneously displays the character you're 
editing in all six character modes (the three supported by BASIC and the other three 
supported only by the hardware). As you use a Joystick Controller to edit the character 
in an eight-by-eight grid, you see immediately how each change affects the character in 
every mode. When you want to experiment with combining characters, merging them to create 
larger objects, you can use INSTEDIT's memo pad mode, which lets you work in the lower 
half of the screen in any of the six character modes. It can even help you create objects 
for use with the ATARI computer's system of player missile graphics. 

In addition to point-by-point character editing, INSTEDIT's menu options let you change 
the whole character at once. You may change it to appear as it does in the ROM character 
set, erase it, restore its original shape, invert the colors of the letter and 
background, copy the form of another letter, create a mirror image, rotate it ninety 
degrees at a time, and shift its position within the matrix. Other options let you save a 
character set for further work later and load in a stored character set. Once you've 
finished editing a set, INSTEDIT will store all or part of your character data to 
diskette in the form of BASIC DATA statements, or assembler source code using the .BYTE 
directive, or even an entire BASIC subroutine for incorporating your new character set 
into an existing program. 


REQUIRED ACCESSORIES 
40K RAM 

ATARI Microsoft BASIC (CXS126) 

ATARI S10 Disk Drive 

One ATARI Joystick Controller 


CONTACTING THE AUTHOR 

Users wishing to contact the author about INSTEDIT may write to him at! 

14400 E1m Street 

Osk Perk, Michigan 48237 
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GETTING STARTED 


LOADING INSTEDIT INTO COMPUTER MEMORY 

1« Remove any cartridge from the cartridge slot of your computer* 

2* Plug your J oystick Controller into the first (the leftmost) controller jack at the 
front of your computer console* 

3* Turn on your disk drive* 

4. When the BUSY light goes out, open the disk drive door and insert the Microsoft BASIC 
diskette with the label in the lower right-hand corner nearest to you* 

5* Turn on your computer and your TV set* Microsoft BASIC will automatically load into 
computer memory* The free memory message, copyright notice, and right arrow cursor will 
display on your TV screen* 

6* Remove the Microsoft BASIC diskette and insert the INSTEDIT diskette* Type RUN 
"DUNSTEDIT" and press the RETURN key* 

7* After a few seconds of setup time, INSTEDIT's five-part screen, described in the next 
section, will display* 



USING INSTEDIT 


INTRODUCTION 

Why create custom character sets? 

Creating custom character sets can serve a number of purposes* For examp le, you might 
want a custom character set for your computer programs for the same reason you'd want a 
changeable typehead on a typewriter! you may need special math symbols, chemistry 
symbols, foreign language alphabets, or a special typeface to set the mood for a 
particular program* 

On a more sophisticated level, you may want to develop special graphics characters as a 
substitute for the plot-and-draw method for producing high-resolution graphics* By 
positioning several characters together, you can create a high-res picture as easily as 
you can print a character string* You can achieve the same resolution with custom mode 0 
characters as you can with mode 8 drawing* The difference is that by using specially 
designed characters, you avoid the high memory usage required for mode 8, as well as the 
tedious and slow plotting of each point and line* You can put the finished drawing on the 
screen much more quickly, achieving smooth animation in BASIC just by printing strings of 
characters in succession, each representing a figure in a different position* 

Using machine-language subroutines, you can extend your work into developing 
professional-quality, fast-action arcade games with full color, high-res animation* Using 
custom character sets in this way introduces a new level of graphics power and 
flexibility* If you're familiar with the ATARI computer's player missile graphics system, 
you can even use INSTEDIT to design players* 

How INSTEDIT works 

When you press a key on your ATARI computer's keyboard, one of 128 different characters 
appears on your TV screen. The shape of each character is determined by a collection of 
data stored in computer memory* INSTEDIT lets you change this data, and thus the shape of 
the characters, as easily as drawing a picture* 

The procedure is as follows* You use the computer's keyboard to select the character you 
want to edit* A large-scale model of this character then displays in an eight-by-eight 
grid* Using a joystick, you move a cursor to any of the 64 squares and modify the 
character's shape — add or remove color by pressing the red trigger button (if color is 
already present, pressing the button erases it; if color is absent, pressing the button 
adds color)* As you change the model character, these changes appear in the samples of 
the character, which are displayed in each character mode. Additional editing features 
let you experiment further with your characters* You can save your finished set on 
diskette or cassette for future editing, or you can incorporate it into a BASIC or 
assembly language program* 



INSTEDIT'S MENU 


INSTEDIT's display screen is divided into five areas* It looks roughly as follows! 
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Figure 1 INSTEDIT's Display Screen 


(1) Submenu of advanced editing features* usable with the main menu's EDIT option* 

(2) Frame for the S-x-S character grid* Initially* this frame contains the program 
title* Prompts also display in this area* 

(3) Main menu of program options* Underneath the options are three sample rows of the 
model character (?) in mode 0* in both normal and inverse video* 

(4) Mode 0 display of the entire character set (in Internal Character Set order)* 

(5) The model character (?) displayed in the other five character modes * in this order! 

(1) Instruction Register (IR) Mode 3 

(2) IR Mode 4 

(3) IR Mode 6 (BASIC GRAPHICS Mode 1) 
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(4) IR Mode 5 

(5) IR Mode 7 (BASIC GRAPHICS Mode 2) 

IR Modes 3, 4, and 5 are character modes supported by the hardware, but not by ATARI 
BASIC* The appendix discusses these hardware modes, sometimes referred to in ATARI 
manuals as ANTIC modes* 


MENU SELECTIONS 

You select a menu function by pressing the key matching the first letter of the function* 

The functions are as follows* 

E EDIT 

When you press the letter "E", the prompt, WHICH CHARACTER TO EDIT?, displays in the 
center frame* Type in your desired character using the LOWR or CTRL key, as 
appropriate, to edit a lowercase or control character* If your desired character is 
an editing symbol, such as one of the arrows, do not press the ESC key before 
pressing the combination of keys used to carry out the edit function* 

After you select a character to edit, your choice displays at the top of the main 
menu and in each of the screen locations initially occupied by the question mark* In 
addition, a large-scale model displays in the center frame, along with a yellow 
cursor* 

Use your joystick to move the cursor within the frame to edit the character* Press 
the red trigger button to change the square — to color an empty square, or erase a 
colored square* Each of the sample characters reflects your changes as soon as they 
occur,* however, the menu and prompt lettering remain in the standard character set* 

While in EDIT mode, you can also use the submenu options of ATARI, BLANK, COPY, 
INVERT, MIRROR, RESTORE, and TWIST, explained below* After you finish editing a 
character, you can go to another by pressing the "E" again, or you can select the 
SAVE, LOAD, or WRITE function* 

The Submenu functions are as follows* Select a function by pressing the matching 
letter* 

A ATARI 

Restores the character being edited to its normal (ROM set) appearance* 

B BLANK 

Clears the whole character currently being edited, giving you a clean 
background on which to design a new character* 
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C COPY 


Replaces the character currently being edited with any other character* After 
pressing "C", the prompt , WHICH CHARACTER TO COPY?, displays in the center 
frame* Type in your desired character* The current character then becomes a 
duplicate of that character* 

I INVERT 

Reverses the colors of the current pattern* All colored squares change to 
background and vice versa* 

M MIRROR 

Changes the character to the mirror image of its present shape* If the 
character is symmetrical, no change is apparent* 

R RESTORE 

Restores the original character as it appeared the last time you pressed "E" 
for EDIT* Any intermediate changes are lost* 

T TWIST 

Rotates the entire character on its axis ninety degrees clockwise each time you 
press "T"* 

+- 11 -+ SHIFT 

Depending on which arrow key you press, shifts the whole character up a line, 
down a line, one square to the left, or one square to the right* You can repeat 
the function by holding down an arrow key* 


S SAVE 

Use this function to store the complete current character set as a data file on 
diskette* You can then continue editing the set later, or you can incorporate it 
into another program* 

When you press "S", the prompt asks you to name the data file* Enter a file name and 
press the RETURN key* Don't include an extender J the program auomatically adds the 
extender "♦SET" to your file name, to identify it as a character set data file* 

When the program finishes storing the character set to diskette, the message SAVE 
COMPLETE displays in the center frame* If an error occurs so that the program can't 
complete saving your character set, an error message will display in the center 
frame, after which the original prompt redisplays* By consulting your BASIC manual, 
you should be able to determine from the numbered I/O error message whether the 
diskette you're using contains no free sectors, is damaged, or contains a 
write-protected file of the same name as the one you're trying to save* 




To cancel a SAVE* press the RETURN key instead of entering a file name* The message 
CANCEL SAVE displays in the center frame* 

Although editing character sets might look like drawing, what is really occurring is 
plain old data manipulation* As is true any time you work with data, saving your 
revisions every so often is good practice* This protects you from calamities such as 
your cat pulling out the cord from the wall outlet, thereby wiping out an 
afternoon's worth of work* How often you save you work depends on how much of it 
you're willing to lose! 

L LOAD 

Use this function to load a previously saved set from diskette* First, the program 
asks you to type the name of the file to be loaded and then press the RETURN key* 

Enter only the name you saved} the program automatically appends the extender "♦SET" 
to your file name* To recall the name of a file, enter an asterisk (*> — the first 
ten data files in the directory will display at the top of the Submenu area* Display 
additional file names by pressing the asterisk again* Like the Save function, you 
can cancel a Load by pressing the RETURN key without first entering a file name* 

The message LOAD COMPLETE displays after a successful load* A numbered error message 

will appear if the program can't load the file, and the original prompt then 

redisplays* In such a case, check the error codes in your BASIC manual to determine 

the cause of the error* Avoid using any of the I/O commands (Save, Load, or Write) 

without first making sure your diskette is inserted and the disk drive door is 

dosed* Otherwise, the drive will keep trying to carry out the program's 

instructions until a timeout occurs* This activity could continue for a couple of 

minutes, during which time you might think the program has crashed* If one of these 

situations occurs, just be patient until the timeout occurs and then correct the 

problem and continue* 

W WRITE 

Use this function to store a file on diskette in such a form that you can 
incorporate it into an existing program* To provide flexible alternatives for 
fullest use of your newly defined characters, INSTEDIT can write yoOr character set 
data in statements you can make part of either BASIC or assembly language programs* 

In addition, Note 1 in the "Applications Notes" section explains an easy way to have 
a BASIC program read in a new character set from a data file, using the LOADSET*LST 
subroutine induded on the INSTEDIT diskette* 

When you press "W", a submenu displays the WRITE options: (1) DATA and (2) *BYTE* 
Explanations of these options follow* 


i 




(1) DATA 


Use this option to save any character or group of characters to diskette in the form of 
numbered BASIC DATA statements* This option is useful in cases where you have only a 
couple of characters to be altered and don't want to read in the whole set using the 
LOADSET*LST file* It's also suitable for occasions when you want to distribute printed 
listings of your program* The DATA option is also ideal for using the characters created 
with INSTEDIT for player missile graphics* Because both players and text characters are 
eight bits wide, character data can be POKEd into player memory without alteration, and 
it will produce a player the same shape as the character* 

After selecting the DATA option, a prompt requests the name of the data file under which 
the program will save your character set data* The program automatically adds the 
extender *DAT to your file name so that youTl recognize it as a DATA statement file* 

Type in your desired file name and press the RETURN key* 

Next, the program prompts you to enter the starting line number for the statements and 
then the increment between line numbers* If, for example, you enter 1000 as your starting 
line number and 10 as your increment value, the resulting file will contain statements in 
the form* 

1 00 0 DATA &Q0 ,&Q0 ,&00 , * * ♦ ♦ 

1010 DATA &A4,&46,&57, ♦ ♦ ♦ 

The program then asks users to press the key of the first letter to be saved to the file 
and the number of consecutive letters starting with that letter that are to be written to 
the file* Consecutive letters mean the order of the Internal Character Set (corresponding 
to the order of the complete character set in the middle area of the INSTEDIT display), 
not ATASCII order* A listing of consecutive order is in Appendix K of the Microsoft 
BASIC Instruction Manual * Hence, if you want to write a file with data for the letters A 
through Z, you first press "A" and then ,, 26" to specify the number of characters to be 
saved* To write a file containing the whole set, you first press the SPACE BAR (which is 
the first character in the Internal Character Set), and then type 128 for the number of 
characters* 

After you enter this information, the prompt HIT RETURN WHEN READY displays* You can now 
insert the proper diskette* When you press the RETURN key, the program will write the 
selected characters to the file in LIST format* The message WRITE DONE displays after the 
program completes the write activity* The HIT RETURN WHEN READY prompt redisplays if the 
program can't complete the activity* You can cancel the option by pressing the ESC key 
instead of the RETURN key* 

The program stores character data in groups of 24 bytes (three characters) per program 
line* You can merge the completed data file with another BASIC file by loading the latter 
and then using the MERGE command* 


(2) *BYTE 


Use this option to produce data files suitable for immediate integration into assembly 
language source code* The option is similar to the DATA option* However, instead of 
writing the data file in the form of numbered BASIC DATA statements, this option produces 
numbered lines beginning with the *BYTE directive and followed by the data in hexidecimal 



form* The output produced takes this form! 


1000 ♦ BYTE $00, $49, $2F, $FC, $4B, $0B, $BE, $C7 

You can enter the data file directly to the Editor using the Command ENTER #Dtfilespec* 
Diskette files produced by this option have the extender *BYT ♦ The *BYTE option writes 
only one character's (eight bytes) worth of data per line* 


MEMO PAD MODE— OPTION key 

Press the OPTION key to enter and exit Memo Pad mode* This mode, like the ATARI memo pad 
lets you print any combination of characters just to see how they look* INSTEDIT, 
however, doesn't limit you to graphics mode 0* You can choose any of the six character 
modes in which to print combinations of characters* 

After pressing the OPTION key, a prompt tells you to type a number between 0 and 7* Type 
in 0, 1, or 2 to set up the bottom half of the screen in the BASIC graphics mode of the 
corresponding number* Type in 3, 4, or 5 to set the Memo Pad to the corresponding IR 
mode* Type 6 to use the Memo Pad but not clear the bottom of the screen, which usually 
occurs when you choose a new mode* This last choice lets you go back and forth from EDIT 
mode to Memo Pad without changing the contents of the Memo Pad* Type a 7 to restore the 
lower screen to its initial configuration* 

After you choose a mode for the memo pad, the program sets the lower half of the screen 
to that mode* The cursor, which is visible only in BASIC mode 0 and IR mode 3, is 
positioned in the upper right-hand corner of the pad* You can then print characters and 
set up various combinations of edited characters to see their interconnection* You can 
use a group of characters to form one large picture, or you can use several characters 
stacked vertically to create a tall player* 

To return to EDIT mode, press the OPTION key again* The lower half of the screen remains 
the same while you edit characters, until you press the OPTION key again* Once you press 
OPTION, you clear the lower screen by choosing a mode, or you exit by pressing the M 7", 
which reinitializes the screen* 



APPLICATION NOTES 


(1) The file provided under the name LOADSET.LST is a subroutine that can be MERGEd into 
your Microsoft BASIC programs, and which will read one of your saved character sets from 
the disk, directly into the area of memory set aside by the OPTION CHR1 command. To used 
the subroutine, MERGE it into your program, and substitute the name of your set for the 
example name provided (DtCOMFUTER.SET). If the numbers used are incompatible with your 
program, use the RENumber command to change them. Now your program will load in your new 
character set instantly! 


One thing that you should remember about the OPTION CHR1 command is that it saves the 
area behind the display data for character data. If you change graphics modes, to a mode 
requiring more memory, you will find that your data area is now display area, and no 
longer safe! The only way to make sure that the area will remain safe is to give the 
OPTION CHR1 command after calling the most memory-intensive mode used by your program. 

(2) INSTEDIT allows you to you to view edited characters as they appear in IR modes 3,4, 
and 5. Although a complete treatment of the Display List is way beyond the scope of this 
manual, a couple of short BASIC routines are included below which will set up a full 
screen of each of the IR modes. These will allow you to experiment with these modes, and 
to use the Script set included with INSTEDIT, which requires the use of IR Mode 3. For 
further information on these modes, consult the Appendix, and the Selected Bibliography, 

In each case, start with! 


10 GRAPHICS 0 ;DL=PEEK<560 )+256*F'EEK 561 


For IR Mode 35 


i 


20 POKE DL + 3 , 67 t FOR 1-6 TO 23 : POKE DL+1,3 
DL+24 * PEEK ( 560 ) JPOKE DL+25 , PEEK ( 561 ) t POKE 


NEXT I ♦ POKE 
DL.+26 1 65 


For IR Mode 4J 



POKE DL+3,68:F0R 1=6 TO 


28 t POKE DL.+I t 4 ♦ NEXT I 


For IR Mode 5J 


20 POKE DL+3,69tF0R 1=6 TO 
DL+ 17, PEEK (560 ) ♦ POKE DL+18 


16: POKE DL +1,5: NEXT I : POKE 
PEEK (561 > :POKE DL+19,65 


(3) One way of getting more colors on a Mode 0 or Mode 8 screen is by using color 
artifacts* You will notice that if you put dots only in odd or even columns (i*e** 
without ever putting two dots side-by-side)* you will generate a couple of new colors* 
While it is recommended that you avoid this for text characters* it might be useful for 
graphics characters* 


(4) One promising application that seems to be a natural would be to design a series of 
characters depicting the face cards of a deck of playing cards* Although I haven't had 
the time to try my hand* I would be interested in hearing from anyone who designs such a 
set* 


(5) Using the data generated by Write* Option 2* it is fairly easy to plot out Mode 0 
characters on a Graphics Mode 8 screen* so that text and map-plot graphics can appear on 
the same horizontal line* As an example* use Option 2 to generate a file with DATA 


* 


- 1 0- 



statements for 26 letters. Type NEW, ENTER the data, then type in the following program: 

10 GRAPHICS 8 J DM=PEEK ( 560 ) +256* ( PEEK ( 561 ) + 4 
:DM=PEEK(DM)+256*PEEK(DM+1 ) : OFF=1680 

20 FOR 1 = 1 TO 25:F0R J = 0 TO 7 * READ At POKE DM+OFF+ J*40+I , A 
: NEXT J J NEXT I 

30 GOTO 30 

By varying the offset constant (OFF), you can position these characters around the screen. 

(6) As mentioned in the Menu section, the data generated by Write Option 1 or 2 can be 
used directly to define Players for Player-Missile Graphics. This data can be FOKEd 
directly into the area reserved for Player data. J ust remember that data from more than 
one character will stack up vertically, one byte per horizontal line. Also, to save 
space and time, remove any 0 data that precedes or follows the actual player shape. 

You may want to keep in mind that Player-Missile Graphics offers three width options for 
each Player. Therefore, you may make use of INSTEDIT'S display of the double-wide 
characters of Graphics Modes 1 and 2, as well as the large center display (which itself 
is 1 maximum-width player) to visualize the appearance of the Players you design in 
varying widths. 
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TROUBLESHOOTING 


(1) Normally, about the only type of problems encountered will be related to 
Input/Output. Examples of such errors are use of illegal disk, file names, trying to write 
to locked files, trying to read non-existent files, or trying to read an 
improperly-positioned tape. INSTEDIT returns a numbered error message when a load or 
save fails, and returns to the last prompt, This gives you an opportunity to check your 
cassette or disk, make sure everything is set up right, and try again, or cancel. 

(2) At most times the user is protected against accidental use of the editing keys in a 
way which would interfere with the screen display. However, full editing functions are 
restored when the user is requested to input information longer than one character, such 
as a file name. During these times, accidental use of an editing function such as the 
line delete may disrupt the display. If this occurs, complete the function in process. 

Then, hit the OPTION key to enter Memo Pad mode. Select option 7, Exit. This will 
restore the screen to its original configuration. 

(3) While the BREAK key has been disabled, the SYSTEM RESET key still works. If you 
accidentally press the SYSTEM RESET key, you can restart the program by typing RUN. If 
you do, however, youTl lose all previous character data. To save your data, before 
typing RUN type GOTO 2000. This statment lets you enter the Save routine without 
clearing character data. When the "SAVE COMPLETE" message appears, you may press the 
SYSTEM RESET key and RUN the program. 
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APPENDIX 


ATARI'S "HIDDEN" CHARACTER MODES 

The reason that Atari computers are able to offer such a large number of Graphics modes 
is that they use a separate graphics microprocessor to handle the screen display. This 
chip receives instructions on how to display data from a simple program contained in RAM. 

If you are using BASIC, the computer writes this program every time you give a GRAPHICS 
command. But since this program is in RAM, it is possible for the user to alter it with 
the POKE command. Several articles have appeared in magazines giving instructions on how 
to change this program, called the Display List, so that many different graphics modes 
can appear on the screen at the same time. A step-by-step plan for creating these mixed 
Display Lists appears in Appendix B of the Atari Hardware Manual (available from Atari 
Customer Service). The key step involves changing the DISPLAY instruction. This 
instruction consists of a number from 2 to 15, Each time it appears, it orders the 
graphics chip to display one line of a particular mode. For example, POKEing in a 2 
orders the chip to display one line of Mode 0, a 6 orders up one line of Mode 1, a 7 one 
line of Mode 2, etc. Notice how the numbers 3,4,5, were skipped? These are the DISPLAY 
instructions for the "hidden” character modes. 

When I first tried POKEing those DISPLAY instructions into a Mode 0 Display List, I came 
up with some pretty funny-looking characters that I really didn't understand. In order 
to find out the purpose behind these modes, which are not supported by BASIC, I had to 
turn to the Hardware Manual. It outlines, in fairly technical terms, some hardware 
features which are not explained by the reference material supplied with the computer. 

To help in the explanation of these modes, I have listed two short programs. The first 
of these (Listing 1) demonstrates what is referred to in the Hardware Manual as 
Instruction Register (IR) Mode 3, In Line 10, I POKE a 3 into bytes 19-26 of the Display 
- List, producing a screen which is 1/2 BASIC Graphics Mode 0 and 1/2 IR Mode 3. Next, the 
whole character set is printed in both modes (Line 30). Finally, a few adjacent 
characters are printed in both modes for the purpose of comparison (Lines 40-45). 

When this program is run, the IR Mode 3 characters at the bottom of the screen do not 
appear to be much different than the mode 0 characters at the top. On more careful 
examination, however, some differences can be detected. First, there is more room 
between the rows of characters in IR Mode 3. This is seen in the fact that while the 
four diagonal graphics characters in the middle of the screen form a diamond shape in 
Mode 0, there is a gap between the top and bottom triangles in IR Mode 3. Also, the 
cursor is taller in that mode. The second difference occurs only in the last 32 
characters of the IR Mode 3 set. These characters appear to be shifted, so that the top 
part of the character has been cut off and moved below the bottom of the character. 

According to the Hardware Manual, there is a simple reason for these differences. By 
creating a longer block for these characters, and having some appear at the top of the 
block and some at the bottom, the user can create a custom character set with true 
descenders for lower case letters like "y" and "p". In order to explain exactly how this 
mode accommodates these changes, however, we must first review the method by which the 
computer determines the shape of a character. 

When the computer wants to display screen data as a graphics character, it must look up 



the shape of the character in a table stored in memory* To find this table, it looks up 
its location in a pointer held in memory location 756 (decimal)* Normally, this pointer 
holds the number 224, because the ROM character data is stored starting at page 224 (this 
is equal to memory location 57344, decimal)* If you are using a custom character set, 
such as those created with INSTEDIT, the pointer will hold the beginning location of that 
set of data in RAM* Each character is represented by 8 bytes of data* As each of these 
bytes is composed of 8 binary digits (or bits), we can picture this data in the form of 
an 8x8 grid* Figure 1 shows how the data for the upper and lower case letter "L" is 
interpreted into the character seen on screen* In this drawing, each horizontal row 
represents one byte (the numeric value of which is given on the left)* Each vertical 
column represents a bit place* A darkened square represents a "1" state in the 
corresponding bit location (the bit values, which equal the successive powers of 2 from 2 
to the 0 (1) to 2 to the 7th (128) are shown at the top of each column)* So, for 
example, no squares are darkened in the top row of Figure 1(a), and therefore the first 
byte has a value of 0* In the second through sixth rows, where bits 5 and 6 are 
darkened, the byte value is 96 (64+32)* 

In IR Mode 3, however, these same characters are set up in a 10x8 grid* Two blank scan 
lines are inserted below each of the first 96 characters (see Figure 2(a))* The last 32 
characters, which include the lower-case alphabet, receive special handling* When one of 
these characters is set up in the grid, the first two bytes are shifted down to the 
bottom two lines (see Figure 2(b))* This shift of the last 32 characters means that they 
use the bottom 8 lines of the grid, while the other characters use the top 8 lines, thus 
enabling the use of the bottom two lines for descenders* A practical example of the use 
of this mode can be seen in the SCRIPT set, which is included with INSTEDIT* You will 
note that while the mode accommodates the characters with descenders very well, the tall 
characters such as the lower-case "b" and “d" must be transferred to the spot reserved 
for their respective Control-characters, so that they will not be shifted down, and can 
attain their full height* 

The other two hardware-supported character modes are demonstrated by the program in 
Listing 2. Lines 10-20 of that program set up the screen half in IR Mode 4, and half in 
IR Mode 5* Line 30 prints the full character set in each mode* Line 40 changes the 
background color for better visibility* The rest of the program enables the use of the 
console switches to change the color and luminescence value of each register* The SELECT 
button determines the register, START changes the color of that register, and OPTION the 
brightness* 

These two modes are 4-color character modes* The only difference between these two modes 
is that IR Mode 5 characters are twice as high as those of IR Mode 4. Unlike BASIC modes 
1 and 2, these IR Modes can mix colors within a particular character* 

Upon looking at the standard character set in these two modes, it will be apparent that 
these modes are not really suitable for text characters* When used with custom-designed 
graphics character sets, however, four-color graphics with the same resolution as BASIC 
Graphics mode 7 can be created, and placed on the screen just by PRINTing a string of 
characters* 

To enable this colorful display, the computer divides each byte of character display data 
into 4 groups of 2 bits each* These groups determine the color of the four pixels per 
row* The four possible combinations produce the following colors! 



Neither bit set — displays the background color (register 4) 

Right bit set — displays the color in register 0 
Left bit set — displays the color in register 1 

Both set — displays the color in register 2 for normal video, and the color in 
register 3 for inverse video characters 

Because two bits are needed to determine the color of each pixel, the horizontal 
resolution is cut in half* Figure 3 shows how this affects letters in the existing 
character set* You should be able to verify this effect by changing the color registers 
in the demonstration program by using the console switches as explained above* 













* 
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0 REM xx LISTING 1 

1 REM xx DEMO OF IR MODE 3 

2 REM xx by Sheldon Leenon 

3 REM xx 

5 REM xx SET UP MIXED-MODE SCREEN 

6 REM xx 

10 ? CHR$ ( 125 ) J X=PEEK ( 560 ) +PEEK < 561 ) X256+19 t FOR 1 = 0 TO 7 i POKE X + I,3 

20 NEXT I t POKE X+8,65;P0KE X+9 , PEEK ( 56 0 ) : POKE X+l 0 , PEEK < 561 ) 

21 REM x 

25 REM x SET UP COMPARISON CHARACTERS 

26 REM x 

30 GOSUB 60 t PRINT AT (2,16);" " J J GOSUB 60 

4 0 PRINT AT ( 10 , 12) JCHR$(6) ;CHR$<7) 

41 PRINT AT (10,13) ;CHR$(7) ;CHR$(6) LI " J CHR* ( 160 ) 

45 PRINT AT ( 1 0 , 1 4 ) ; CHR* ( 6 ) ; CHR* ( 7 ) J " " J CHR* ( 160 ) J "LI " 

46 PRINT AT ( 1 0 , 15 ) } CHR* ( 7 ) } CHR$ ( 6 ) J PRINT AT (15,10);" " 

50 POKE 752, i; PRINT AT ( 2 , 9 ) ; CHR$ ( 28 ) 

51 REM x 

55 GOTO 55 

56 REM x 

60 FOR 1=0 TO 127;? CHR$ ( 27 ) f CHR$ ( I ) ; ; NEXT IJRETURN 
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20 
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26 

30 

31 

35 

36 

40 

41 

45 

46 
50 

err? 
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54 
56 
58 
6 0 
65 
70 


REM 

REM 

REM 

REM 

REM 

REM 


XX 

XX 

XX 

XX 

XX 

XX 


LISTING 2 

DEMO IF IR MODES 4 
by Sheldon Leenon 


AND 


5 


SET UP MIXED-MODE SCREEN 


? CHR$(125) tX«PEEK( 560) +PEEKC 561) *256+3: POKE X,69 

FOR 1 = 3 TO 8J POKE X + I , 5 1 NEXT 1 1 FOR 1 = 9 TO 16: POKE X+I,4:NEXT I 

POKE X+l 9, 65: POKE X+2 0 , PEEK < 56 0 >: POKE X+2 1 , PEEK ( 56 1 )J POKE 752, It? 


REM * 
REM * 
REM x 
PRINT 
REM * 
REM x 


PRINT CHARACTER SETS 

at (1,0) i" •• ;: gosub 6o:? 

CHANGE BACKGROUND COLOR 


:? 


: GOSUB 60 


REM * 

FOR DELAY=1 TO 1500: NEXT DELAY:? CHR$ ( 253 ) : SETCOLOR 8,0,14 
REM x 

REM * COLOR REGISTER CHANGE ROUTINE 
REM x 

R=0 :s=5: GOSUB 70 

S=PEEK ( 53279 >: IF S=5 THEN R=R + 1 +5* ( R~4 ) ♦ GOSUB 70 
IF S=6 THEN C=C+ 1 + 1 6* < C= 1 5 ) : SETCOLOR R + 4 , C , L : GOSUB 
IF S = 3 THEN L = L. + 2+16* ( L=14 ) : SETCOLOR R + 4 , C , L J GOSUB 
FOR DELAY=1 TO 100JNEXT DELAY: GOTO 52 
F OR 1 = 1 TO 154:? CH R* ( 27 ) t CHET ( I ) : : NEXT I 
FOR 1 = 156 TO 255 : ? CHR* (27) $ C H R $ ( I ) t X NEXT I : RETURN 
M= PEEK ( 7 0 8 + R ) t C = INT < M/16 ) : L=M-16*C 


•7 it 

/ vJ 

80 
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B X BL I OGRAPHY 


* 


The following magazine articles will aid the reader 
in understanding the subjects of character set editing and 
PI aver— Mi ssi 1 e Graphics: 


"Outpost: Atari — Missile Graphics Mysteries Revealed" , 

George Blank. Creative Computing ^ January 1931, p . 1 76 

" Character Generation on the Atari", Charles Brannon, 
COMPUTE : . February 1931, p.76 


" Player-Missile Graphics with the Atari PCS", Crawford, 
COMPUTE ? , January 1931, pp. 66—77 


” An Introduction to Atari Graphics" , Crawford and Winner, 
BYTE, January 1981, pp . 13—32 

" Designing Your Own Atari Character Sets", Gary Patchett, 
COMPUTE I , March 1931, p.72 


♦ 


Besides the articles mentioned above, readers who 
have some technical background will want to consult the 
Atari Personal Computer System Hardware Manual , which is 
available from Atari Customer Service. This manual give 
complete details concerning hardware features. 
Appendices A and B, which deal with PI aver —Mi ssi 1 e 
Graphics and mixing Graphics Modes, will be of particular 
i nterest . 
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LIMITED WARRANTY ON MEDIA AND HARDWARE ACCESSORIES. 


We, Atari, Inc., guarantee to you, the original retail purchaser, that the medium on 
which the AFX program is recorded and any hardware accessories sold by APX are free from 
defects for thirty days from the date of purchase. Any applicable implied warranties, 
including warranties of merchantability and fitness for a particular purpose, are also 
limited to thirty days from the date of purchase. Some states don't allow limitations on 
a warranty's period, so this limitation might not apply to you. If you discover such a 
defect within the thirty-day period, call APX for a Return Authorization Number, and then 
return the product along with proof of purchase date to APX. We will repair or replace 
the product at our option. 

You void this warranty if the APX product: (1) has been misused or shows signs of 
excessive wear? (2) has been damaged by use with non-ATARI products} or (3) has been 
serviced or modified by anyone other than an Authorized ATARI Service Center. Incidental 
and consequential damages are not covered by this warranty or by any implied warranty. 
Some states don't allow exclusion of incidental or consequential damages, so this 
exclusion might not apply to you. 


DISCLAIMER OF WARRANTY AND LIABILITY ON COMPUTER PROGRAMS. 

Most APX programs have been written by people not employed by Atari, Inc. The programs we 
select for APX offer something of value that we want to make available to ATARI Home 
Computer owners. To offer these programs to the widest number of people economically, we 
don't put APX products through rigorous testing. Therefore, APX produts are sold "as is", 
and we do not guarantee them in any way. In particular, we make no warranty, express or 
implied, including warranties of merchantability and fitness for a particular purpose. We 
are not liable for any losses or damages of any kind that result from use of an APX 
product. 




REVIEW FORM 


We're interested in your experiences with APX programs and documentation * both favorable and 
unfavorable. Many software authors are willing and eager to improve their programs if they know 
what users want. And, of course* we want to know about any bugs that slipped by us* so that the 
software author can fix them. We also want to know whether our documentation is meeting your needs 
You are our best source for suggesting improvements! Please help us by taking a moment to fill in 
this review sheet. Fold the sheet in thirds and seal it so that the address on the bottom of the 
back becomes the envelope front. Thank you for helping us! 

1. Name and APX number of program 

2. If you have problems using the program* please describe them here* 


3. What do you especially like about this program? 


4. What do you think the program's weaknesses are? 


5. How can the catalog description be more accurate and/or comprehensive? 


6. On a scale of 1 to 10* 1 being "poor" and 10 being "excellent"* please rate the following 
aspects of this program'? 

Easy to use 

User-oriented (e.g.* menus* prompts* clear language) 

Enjoyable 

Self-instructive 

Useful (non-game software) 

Imaginative graphics and sound 


7. Describe any technical errors you found in the user instructions (please give page numbers). 



3* What did you especially like about the user instructions? 


?♦ What revisions or additions would improve these instructions? 


10* On a scale of 1 to 10, 1 representing "poor 11 and 10 representing "excellent**, how would you 
rate the user instructions and why? 


11* Other comments about the software or user instructions* 


I I 

ISTAMPI 


ATARI Program Exchange 
Attn! Publications Dept* 
P*0* Box 50047 
60 E* Plumeria Drive 
San Jose, CA 95150 
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[seal here] 
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Microsoft BASIC version 
APX-20113 March 1982 
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